## Lab 2

# The only time you have to do math

### Introduction

In this experiment, we are going to create a simple 4-bit Arithmetic and Logic Unit (ALU). First, a single bit full adder will be designed using basic Boolean logic. Then, a 4-bit ripple-carry adder will be created structurally using the single bit full adder. Finally, the power of operators will be leveraged in order to behaviorally describe a 16 function ALU.

## Pre Lab - Operators and Conversions Review

Write the logic equations for a single bit full adder with inputs A, B, Cin, and outputs Y, Cout.

Draw a black box diagram for the single bit full adder described above.

Draw a block diagram of a 4-bit ripple-carry adder made of single bit full adders, with 4 bit inputs A and B, a single bit input Cin, a 4-bit output S, and a single bit output Cout.

## 1 Back to Digital Logic Design

#### 1.1 Background

A single bit-full adder is a simple circuit that can be used to perform binary arithmetic. By creating a truth table and using a Karnaugh map to minimize the logic, a gate level description can be made to represent the dataflow.

Shown below is a gate level diagram for a single-bit full adder:



Figure 2.1: Single-Bit Full Adder Gate Diagram [1]

#### 1.2 Tasks

- Use the gate level schematic provided above to create a single-bit full adder called adder.
- Design an entity for the 4-bit ripple carry adder described above called ripple\_adder by using a structural design methodology. Do so by placing and connecting 4 single-bit full adders based on the block diagram given below
- Create a basic simulation testbench for the 4-bit ripple carry adder to prove its operation

Note: This part is NOT being put on the board.



Figure 2.2: Single-Bit Full Adder Gate Diagram [2]

## 2 Somebody did the work already

#### 2.1 Background

Due to the power of VHDL and the operators defined in the numeric\_std library, many of the basic Arithmetic and Logical functions have already been defined and are synthesize-able without having to create your own hardware implementations. For this part, we are going to leverage that in order to create a 4-bit, 16 function ALU with the following operations:

| opcode | function                        | opcode | function                         |
|--------|---------------------------------|--------|----------------------------------|
| x"0"   | A + B                           | x"8"   | A >>> 1 (right shift arithmetic) |
| x"1"   | A-B                             | x"9"   | not A                            |
| x"2"   | A+1                             | x"A"   | A and $B$                        |
| x"3"   | A-1                             | x"B"   | $A 	ext{ or } B$                 |
| x"4"   | 0-A                             | x"C"   | $A 	ext{ xor } B$                |
| x"5"   | A > B (greater than - see note) | x"D"   | $A \times B$                     |
| x"6"   | A << 1 (left shift logical)     | x"E"   | A nand $B$                       |
| x"7"   | A >> 1 (right shift logical)    | x"F"   | A  nor  B                        |

Notes: For ease of complexity, both in concept and in testing, we are going to use unsigned operands and produce an unsigned output. Many of these functions require certain types for their arguments, be careful with your type conversions. Shifting can be implemented with  $std\_logic\_vectors$  and some indexing tricks (think concatenation). For function 5 (A > B), throw a 1 if true, 0 if false.

Hint 1: It may be worthwhile to look into the "case" structure.

Hint 2: see this https://www.doulos.com/knowhow/vhdl\_designers\_guide/numeric\_std/

#### 2.2 Tasks

- Design the 16 function 4-bit ALU, called my\_alu, described above behaviorally by taking advantage of the numeric\_std library and its associated operators and conversion functions.
- Create a top level design, called alu\_tester, in which you instantiate the ALU and assign its output to the four LEDs on the ZyBo. Assign its three inputs Opcode, A, and B to three different 4-bit std\_logic\_vectors whose values are loaded in from the switches when buttons 2, 1, and 0 respectively are pressed on a rising edge of the clock. Pressing button 3 should clear all 3 signals to 0. The inputs from the buttons will be debounced using the module designed in Lab 1. The output of the ALU will be stored in a 4-bit std\_logic\_vector on each rising edge of the clock.
- Create the appropriate modified XDC file and put the design on the board in order to test it experimentally.

## 3 Credits

#### Sources

- [1] Full Adder Logic Diagram. URL: http://gateoverflow.in/?qa=blob&qa\_blobid=5724651430411155887.
- [2] Ripple Carry Adder Block Diagram. URL: https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/4-bit\_ripple\_carry\_adder.svg/500px-4-bit\_ripple\_carry\_adder.svg.png.

#### Acknowledgments

Gregory Leonberg Original Author Fall 2017

Stephen DiNicolantonio Updates/Modification and LATEX Design Fall 2018